home *** CD-ROM | disk | FTP | other *** search
/ Linux Cubed Series 3: Developer Tools / Linux Cubed Series 3 - Developer Tools.iso / devel / lang / lisp / guile-ii.src / guile-ii / guile-src / libguile / smob.c < prev    next >
Encoding:
C/C++ Source or Header  |  1995-06-15  |  3.7 KB  |  132 lines

  1. /*    Copyright (C) 1995 Free Software Foundation, Inc.
  2.  * 
  3.  * This program is free software; you can redistribute it and/or modify
  4.  * it under the terms of the GNU General Public License as published by
  5.  * the Free Software Foundation; either version 2, or (at your option)
  6.  * any later version.
  7.  * 
  8.  * This program is distributed in the hope that it will be useful,
  9.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  11.  * GNU General Public License for more details.
  12.  * 
  13.  * You should have received a copy of the GNU General Public License
  14.  * along with this software; see the file COPYING.  If not, write to
  15.  * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
  16.  *
  17.  * As a special exception, the Free Software Foundation gives permission
  18.  * for additional uses of the text contained in its release of GUILE.
  19.  *
  20.  * The exception is that, if you link the GUILE library with other files
  21.  * to produce an executable, this does not by itself cause the
  22.  * resulting executable to be covered by the GNU General Public License.
  23.  * Your use of that executable is in no way restricted on account of
  24.  * linking the GUILE library code into it.
  25.  *
  26.  * This exception does not however invalidate any other reasons why
  27.  * the executable file might be covered by the GNU General Public License.
  28.  *
  29.  * This exception applies only to the code released by the
  30.  * Free Software Foundation under the name GUILE.  If you copy
  31.  * code from other Free Software Foundation releases into a copy of
  32.  * GUILE, as the General Public License permits, the exception does
  33.  * not apply to the code that you add in this way.  To avoid misleading
  34.  * anyone as to the status of such modified files, you must delete
  35.  * this exception notice from them.
  36.  *
  37.  * If you write modifications of your own for GUILE, it is your choice
  38.  * whether to permit this exception to apply to your modifications.
  39.  * If you do not wish that, delete this exception notice.  
  40.  */
  41.  
  42.  
  43. #include <stdio.h>
  44. #include "_scm.h"
  45.  
  46.  
  47.  
  48. /* scm_smobs scm_numsmob
  49.  * implement a dynamicly resized array of smob records.
  50.  * Indexes into this table are used when generating type
  51.  * tags for smobjects (if you know a tag you can get an index and conversely).
  52.  */
  53. sizet scm_numsmob;
  54. scm_smobfuns *scm_smobs;
  55.  
  56. #ifdef __STDC__
  57. long 
  58. scm_newsmob (scm_smobfuns *smob)
  59. #else
  60. long 
  61. scm_newsmob (smob)
  62.      scm_smobfuns *smob;
  63. #endif
  64. {
  65.   char *tmp;
  66.   if (255 <= scm_numsmob)
  67.     goto smoberr;
  68.   DEFER_INTS;
  69.   SYSCALL (tmp = (char *) realloc ((char *) scm_smobs, (1 + scm_numsmob) * sizeof (scm_smobfuns)));
  70.   if (tmp)
  71.     {
  72.       scm_smobs = (scm_smobfuns *) tmp;
  73.       scm_smobs[scm_numsmob].mark = smob->mark;
  74.       scm_smobs[scm_numsmob].free = smob->free;
  75.       scm_smobs[scm_numsmob].print = smob->print;
  76.       scm_smobs[scm_numsmob].equalp = smob->equalp;
  77.       scm_numsmob++;
  78.     }
  79.   ALLOW_INTS;
  80.   if (!tmp)
  81.   smoberr:scm_wta (MAKINUM ((long) scm_numsmob), (char *) NALLOC, "newsmob");
  82.   return tc7_smob + (scm_numsmob - 1) * 256;
  83. }
  84.  
  85. /* {Initialization for i/o types, float, bignum, the type of free cells}
  86.  */
  87.  
  88. static scm_smobfuns freecell =
  89. {
  90.   scm_mark0,
  91.   scm_free0,
  92.   0,
  93.   0
  94. };
  95.  
  96. static scm_smobfuns flob =
  97. {
  98.   scm_mark0,
  99.   /*flofree*/ 0,
  100.   scm_floprint,
  101.   scm_floequal
  102. };
  103.  
  104. static scm_smobfuns bigob =
  105. {
  106.   scm_mark0,
  107.   /*bigfree*/ 0,
  108.   scm_bigprint,
  109.   scm_bigequal
  110. };
  111.  
  112.  
  113.  
  114. #ifdef __STDC__
  115. void
  116. scm_smob_prehistory (void)
  117. #else
  118. void
  119. scm_smob_prehistory ()
  120. #endif
  121. {
  122.   scm_numsmob = 0;
  123.   scm_smobs = (scm_smobfuns *) malloc (7 * sizeof (scm_smobfuns));
  124.  
  125.   /* WARNING: These scm_newsmob calls must be done in this order */
  126.   scm_newsmob (&freecell);
  127.   scm_newsmob (&flob);
  128.   scm_newsmob (&bigob);
  129.   scm_newsmob (&bigob);        /* n.b.: two smobs, one smobfuns */
  130. }
  131.  
  132.